package com.sky.mapper;

import com.sky.entity.User;
import com.sky.mapperResult.DailyNewUsers;
import com.sky.mapperResult.TotalUser;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.time.LocalDate;
import java.util.List;
import java.util.Map;

@Mapper
public interface UserMapper {
    /**
     * 根据openid查询用户
     * @return
     */
    @Select("select * from user where openid = #{openid}")
    User getByOpenid(String openid);

    /**
     * 新增用户
     * @param user
     */
    void insert(User user);

    /**
     * 根据用户id查询用户
     * @param userId
     * @return
     */
    @Select("select * from user where id = #{userId}")
    User getById(Long userId);

    /**
     * 根据日期查询每日新建用户数
     * @param map
     * @return
     */
    List<DailyNewUsers> countNewUsersByDateRange(Map<String, Object> map);

    /**
     * 根据日期查询截止end的总用户数
     * @param map
     * @return
     */
    List<TotalUser> countTotalUsersByDateRange(Map<String, Object> map);
}
